// 提供雇佣逻辑的函数 钩子
import { useIntersectionObserver, useIntervalFn } from '@vueuse/core'
import { ref, onUnmounted } from 'vue'
import dayjs from 'dayjs'
// target dom对象
// apiFn api函数
export const uselazyDate = (apiFn) => {
  const result = ref([])
  const target = ref(null)
  const { stop } = useIntersectionObserver(
    // target 是观察的目标dom容器，必须是dom容器，而且是vue3.0方式绑定的dom对象
    target,
    // isIntersecting 是否进入可视区域，true是进入 false是移出
    // observerElement 被观察的dom
    ([{ isIntersecting }], observerElement) => {
      // 在此处可根据isIntersecting来判断，然后做业务
      if (isIntersecting) {
        stop()
        // 调用api函数获取数据
        apiFn().then(data => {
          result.value = data.result
        })
      }
    },
    // 配置选项  图片进入可视区的临界值
    {
      threshold: 0
    }
  )

  return { result, target }
}
// countdown 倒计时秒数
export const usePayTime = () => {
  // 倒计时逻辑
  const time = ref(0)
  const timeText = ref('')
  const { pause, resume } = useIntervalFn(() => {
    time.value--

    timeText.value = dayjs.unix(time.value).format('mm分ss秒')
    console.log(timeText.value, 1)
    if (time.value <= 0) {
      pause()
    }
  }, 1000, false)
  // 组件结束时销毁
  onUnmounted(() => {
    pause()
  })
  // const deleteTimeout = () => {
  //   console.log(1119)
  //   pause()
  // }
  // 开启定时器
  const start = (countdown) => {
    time.value = countdown
    timeText.value = dayjs.unix(time.value).format('mm分ss秒')

    resume()
  }
  return { start, timeText }
}
